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REMARKS 

Claims 1 - 5, ? - 12, and 14 - 40 are pending in the application. Claims 1 - 5, 7 - 12, and 
14 - 40 have been rejected. Claims 1, 8, 16, 21, 26, 31 and 36 have been amended. No new 
claims have been added. 

Claims 1, 8, 16, 21, 26, 31 and 36 are rejected due to informalities and have been 
amended to address this rejection. 

Claims 1 , 2, 3, 5, 8, 9, 10, 12, 16, 17, 1 8, 20-23, 25 - 28 and 30 - 40 stand rejected under 
Chen, U.S. Patent No. 6,625,807* (Chen) in view of Zucker, U.S. Patent No. 5,991,871 (Zucker). 
These rejections are respectfully traversed. 

The present invention generally relates to an optimizing compiler that adds annotation 
information (i.e., compiler annotation) to an executable binary code file. The compiler 
annotation provides information useful for binary translators such that a binary translator does 
not have to use a heuristic approach to translate binary code. Compiler annotation identifies such 
information as function boundaries, split functions, jump table information, function addresses 
and code labels. (Sec e.g., application page 3, liens 1 - 9.) 

More specifically, the present invention, as set forth by independent claim 1, relates to a 
method of producing a binary code file which includes compiling a plurality of source code 
instructions, and outputting a plurality of binary code instructions and compiler annotation. The 
plurality of binary code instructions is executable by a processor of a computer system and are an 
executable and linking format (ELF) binary code file. The compiler annotation is an ELF 
selection. 

The present invention, as set forth by independent claim 8, relates to a method of 
translating a source binary code file which includes translating a plurality of source binary code 
instructions utilizing compiler annotation and the outputting a plurality of target binary code 
instructions. The plurality of source binary code instructions are an executable and linking 
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format (ELF) binary code file and the compiler annotation is an ELF section. The plurality of 
target binary code instructions is executable by a processor of a computer system. 

The present invention, as set forth by independent claim 16, relates to a binary code file 
which includes a plurality of binary code instructions and compiler annotation. The compiler 
annotation enables a binary translator to utilize the compiler annotation to partition the plurality 
of binary code instructions into sections, functions and basic blocks; and build a control-flow 
graph utilizing the plurality of binary code instructions and the compiler annotation. The 
plurality of binary code instructions is executable by a processor of a computer system and the 
instructions arc an executable and linking format (ELF) binary code file. The compiler 
annotation is an ELF section. 

The present invention, as set forth by independent claim 21 , relates to an apparatus for 
producing a binary code file which includes means for compiling a plurality of source code 
instructions and means for outputting a plurality of binary code instructions and compiler 
annotation. The plurality of source binary code instructions are an executable and linking format 
(ELF) binary code file and the compiler annotation is an ELF section. 

The present invention, as set forth by independent claim 26, relates to an apparatus for 
translating a source binary code file which includes means for translating a plurality of source 
binary code instructions utilizing compiler annotation, and means for outputting a plurality of 
target binary code instructions. The plurality of source binary code instructions are an 
executable and linking format (ELF) binary code file and the compiler annotation is an ELF 
section. 

The present invention, as set forth by independent claim 3 1 relates to an apparatus for 
producing a binary code file which includes a computer readable medium, and instructions stored 
on the computer readable medium to compile a plurality of source code instructions, and output a 
plurality of binary code instructions and compiler annotation. The plurality of source binary code 
instructions are an executable and linking format (ELF) binary code file and the compiler 
annotation is an ELF section. 
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The present invention, as set forth by independent claim 36, relates to an apparatus for 
translating a source binary code file which includes a computer readable medium, and 
instructions stored on the computer readable medium to translate a plurality of source binary 
code instructions utilizing compiler annotation, and output a plurality of target binary code 
instructions. The plurality of source binary code instructions are an executable and linking 
format (ELF) binary code file and the compiler annotation is an ELF section. 

Chen discloses a method for register optimization during code translation and utilizes a 
technique that removes the rime overhead for analyzing register usage and eliminates fixed 
restraints on the compiler register usage. The method for register optimization utilizes a 
compiler to produce a bit vector for each program unit (i,e», subroutine, function, and/or 
procedure). Each bit in the bit vector represents a particular caller-saved register. A bit is set if 
the compiler uses the corresponding register within that program unit. During the translation, the 
translator examines the bit vector to very quickly determine which, registers are free, and 
therefore can be used during register optimization without having to save and restore the register 
values. 

Zucker discloses interfacing a binary application program to a computer system. The 
application binary interface includes linkage structures for interfacing the binary application 
program to a digital computer. A function in a relocatable shared object module obtains the 
absolute address of a Global Offset Tabic (GOT) in the module using relative branch and link 
instructions through the computer's link register A dynamic linker constructs a Procedure 
Linkage Table (PLT) and a pointer table for an object module in a process memory image in 
which space is allocated for the PLT, but the PLT is not initially provided. The pointer table 
stores absolute addresses of external functions that cannot be reached by relative branching from 
the module. The PLT receives calls to these functions, gets the absolute addresses from the 
pointer table and branches to the absolute addresses of the functions. The PLT also receives 
calls to functions that can be reached by relative branching from the module, and causes relative 
branching to the functions. 

Zucker sets forth that a binary application object file program is configured in an 
Executable and Linking Format (ELF). More specifically, Zucker sets forth: 
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The object program 60 comprises an ELF header 64 that specifies the number and sizes 
of the sections of the program 60, in addition to other information required by the 
operating system 48. A section header table 66 is also provided, including information 
required to locate all of the sections of the file 60. 

The actual text (program instructions) and data of the program are provided in a number 
of discrete sections, designated as 68 1 to 68^. A dynamic section 70 contains dynamic 
linking information for use by the dynamic linker 54 (Zucker Col. 8, lines 28 -39). 

In generally, neither Chen nor Zucker does not disclose or suggest method of producing a 
binary code file where the binary code file includes binary code instruction and compiler 
annotation where the compiler annotation is an ELF section, as substantially required by each of 
the independent claims. The ELF header 64 of Zucker neither teaches nor suggests the claimed 
binary code file having both binary code instructions and compiler annotation which is an ELF 
section. 

More specifically, Chen and Zucker, taken alone or in combination, do not teach or a 
method of producing a binary code file which includes compiling a plurality of source code 
instructions, and outputting a plurality of binary code instructions and compiler annotation 
wherein the plurality of binary code instructions is executable by a processor of a computer 
system and are an executable andlinktng format (ELF) binary code file and the compiler 
annotation is an ELF section, all as required by claim 1. Accordingly, claim 1 is allowable over 
Chen and Zucker. Claims 2-7 depend from claim 1 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest a method of 
translating a source binary code file which includes translating a plurality of source binary code 
instructions utilizing compiler annotation and the outputting a plurality of target binary code 
instructions wherein the plurality of source binary code instructions arc an executable and 
linking format (ELF) binary code file and the compiler is an ELF section and the plurality of 
target binary code instructions is executable by a processor of a computer system, all as required 
by claim 8. Accordingly, claim 8 is allowable over Chen and Zucker. Claims 9-15 depend 
from claim 8 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest a binary code 
file which includes a plurality of binary code instructions and compiler annotation where the 
plurality of binary code instructions are an executable and linking format (ELF) binary code file 
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and the compiler annotation is an ELF section, all as required by claim 16. Accordingly* claim 
16 is allowable over Chen and Zucker. Claims 17-20 depend from claim 1 6 and are allowable 
for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for 
producing a binary code file which includes means for outputting a plurality of binary code 
instructions and compiler annotation wherein the plurality of source binary code instructions are 
an executable and Unking format (ELF) binary code file and the compiler annotation is an ELF 
section, all as required by claim 21. Accordingly, claim 21 is allowable over Chen and Zucker. 
Claims 22 - 25 depend from claim 21 and arc allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for 
translating a source binary code file which includes means for translating a plurality of source 
binary code instructions utilizing compiler annotation, and means for outputting a plurality of 
target binary code instructions wherein the plurality of source binary code instructions are an 
executable and linkingformat (ELF) binary code file and the compiler annotation is an ELF 
section all as required by claim 26. Accordingly, claim 26 is allowable over Chen and Zucker. 
Claims 27 - 30 depend from claim 26 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for 
producing a binary code file which includes instructions stored on a computer readable medium 
to compile a plurality of source code instructions, and output a plurality of binary code 
instructions and compiler annotation wherein the plurality of source binary code instructions are 
an executable and linkingformat (ELF) binary code file and the compiler annotation is an ELF 
section, all as required by claim 31 . Accordingly, claim 31 is allowable over Chen and Zucker. 
Claims 32 - 35 depend from claim 31 and are allowable for at least this reason. 

Chen and Zucker, taken alone or in combination, do not teach or suggest an apparatus for 
translating a source binary code file which includes instructions stored on a computer readable 
medium to translate a plurality of source binary code instructions utilizing compiler annotation, 
and output a plurality of target binary code instructions wherein the plurality of source binary 
code instructions are an executable and linking format (ELF) binary code file and the compiler 
annotation is an ELF section, all as required by claim 36. Accordingly, claim 36 is allowable 
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over Chen and Zucker. Claims 37 - 40 depend from claim 36 and are allowable for at least this 
reason. 

CONCLUSION 

In view of the amendments and remarks set forth herein, the application is believed to be 
in condition for allowance and a notice to that effect is solicited. Nonetheless, should any issues 
remain that might be subject to resolution through a telephonic interview, the examiner is 
requested to telephone the undersigned. 
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